home *** CD-ROM | disk | FTP | other *** search
- /* > c.Rules
- *
- * $Id: c.rules 1.4 95/04/19 22:44:43 root Rel $
- *
- * $Log: c.rules $
- * Revision 1.4 95/04/19 22:44:43 root
- * Checked in for release
- *
- * Revision 1.3 95/04/18 21:47:27 root
- * *** empty log message ***
- *
- * Revision 1.2 95/04/18 21:42:10 root
- * Tidied for release
- *
- *
- * Control of the implicit suffix rules
- */
-
-
- #include "h.h"
-
-
- /*
- * Return a pointer to the suffix of a name
- */
-
- char *
- suffix(char *name)
- {
- return rindex(name, '.');
- }
-
-
- /*
- * Dynamic dependency. This routine applies the suffix rules
- * to try and find a source and a set of rules for a missing
- * target. If found, np is made into a target with the implicit
- * source name, and rules. Returns TRUE if np was made into
- * a target.
- */
- bool
- dyndep(struct name *np)
- {
- register char * p;
- register char * q;
- register char * suff; /* Old suffix */
- register char * basename; /* Name without suffix */
- struct name * op; /* New dependent */
- struct name * sp; /* Suffix */
- struct line * lp;
- struct depend * dp;
- char * newsuff;
-
-
- p = str1;
- q = np->n_name;
- if (!(suff = suffix(q)))
- return FALSE; /* No suffix */
- while (q < suff)
- *p++ = *q++;
- *p = '\0';
-
- basename = setmacro("*", str1)->m_val;
-
- /*
- printf("$* is : %s\n",basename);
- */
-
- if (!((sp = newname(".SUFFIXES"))->n_flag & N_TARG))
- return FALSE;
- for (lp = sp->n_line; lp; lp = lp->l_next)
- for (dp = lp->l_dep; dp; dp = dp->d_next)
- {
- newsuff = dp->d_name->n_name;
- if (strlen(suff)+strlen(newsuff)+1 >= LZ)
- fatal("Suffix rule too long");
- p = str1;
- q = newsuff;
- while (*p++ = *q++)
- ;
- p--;
- q = suff;
- while (*p++ = *q++)
- ;
- sp = newname(str1);
- if (sp->n_flag & N_TARG)
- {
- p = str1;
- q = basename;
- if (strlen(basename) + strlen(newsuff)+1 >= LZ)
- fatal("Implicit name too long");
- while (*p++ = *q++)
- ;
- p--;
- q = newsuff;
- while (*p++ = *q++)
- ;
- op = newname(str1);
- if (!op->n_time)
- modtime(op);
- if (op->n_time)
- {
- dp = newdep(op, 0);
- newline(np, dp, sp->n_line->l_cmd, 0);
- setmacro("<", op->n_name);
- /*
- printf("$< is : %s\n",op->n_name);
- */
-
-
- return TRUE;
- }
- }
- }
- return FALSE;
- }
-
-
- /*
- * Make the default rules
- */
- void
- makerules(void)
- {
- struct cmd * cp;
- struct name * np;
- struct depend * dp;
-
- /*
- * Some of the UNIX implicit rules
- */
- #ifdef arc
- setmacro("CC", "cc");
- setmacro("CFLAGS", "-i -darc");
- cp = newcmd("$(CC) $(CFLAGS) -c -o $@ $<", 0);
- np = newname(".c.o");
- newline(np, 0, cp, 0);
-
-
- setmacro("AS", "as");
- cp = newcmd("$(AS) -o $@ $<", 0);
- np = newname(".s.o");
- newline(np, 0, cp, 0);
-
- setmacro("YACC", "yacc");
- setmacro("YFLAGS", "");
- cp = newcmd("$(YACC) $(YFLAGS) $<", 0);
- cp = newcmd("mv y.tab.c $@", cp);
- np = newname(".y.c");
- newline(np, 0, cp, 0);
-
- cp = newcmd("$(YACC) $(YFLAGS) $<", 0);
- cp = newcmd("$(CC) $(CFLAGS) -c y.tab.c", cp);
- cp = newcmd("rm y.tab.c", cp);
- cp = newcmd("mv y.tab.o $@", cp);
- np = newname(".y.o");
- newline(np, 0, cp, 0);
-
-
- np = newname(".a");
- dp = newdep(np, 0);
- np = newname(".o");
- dp = newdep(np, dp);
- np = newname(".c");
- dp = newdep(np, dp);
- np = newname(".y");
- dp = newdep(np, dp);
-
- np = newname(".SUFFIXES");
- newline(np, dp, 0, 0);
- #endif
-
- }
-
-